form {
  border: solid 1px #dbdbdb;
  border-radius: 4px 4px;
  max-width: 500px;
  width: 90%;
  margin: 20px auto;
  padding: 20px;
}

.form-section {
  display: flex;
  justify-content: space-between;
  height: 52px;
}

.form-title {
  width: 100px;
  height: 52px;
  line-height: 32px;
  text-align: right;
  font-size: 14px;
  padding: 10px;
}

.form-element {
  height: 72px;
  padding: 10px;
  width: calc(100% - 100px);
  display: flex;
  flex-direction: column-reverse;
  justify-content: flex-start;
}

.input-text {
  outline: none;
  height: 32px;
  line-height: 32px;
  font-size: 14px;
  padding: 0 10px;
  border-radius: 4px 4px;
}

.err-message {
  color: #FF4A60;
  font-size: 12px;
  height: 20px;
  line-height: 20px;
}

.err-message + .input-text {
  border: solid 1px #ff4a60
}

.err-message[error=""] + input {
  border: solid 1px #dbdbdb
}

.buttons-group {
  width: 100%;
  display: flex;
  justify-content: center;
}
